在正式使用 Kubernetes 之前,還有一道最後的關卡:如何與叢集進行溝通。這個問題的答案就是 kubectl
。
在 Kubernetes 環境中,kubectl
是管理和操作叢集的主要工具,其原理是使用 Kubernetes API 與 Kubernetes 叢集的控制面板(Control panel)進行互動。
簡單來說,kubectl
是 Kubernetes 的命令行工具(CLI)。
kubectl
sudo apt-get update
sudo apt-get install -y kubectl
kubectl
版本kubectl version
---
Client Version: v1.29.2
Kustomize Version: v5.0.4-0.20230601165947-6ce0bf390ce3
Server Version: v1.30.0
kubectl cluster-info
---
Kubernetes control plane is running at https://127.0.0.1:39777
CoreDNS is running at https://127.0.0.1:39777/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
kubectl
使用 kubeconfig 檔案來尋找選擇叢集所需的資訊,該檔案包含了 Cluster、User 、Namespace、 authentication 、Context 等資訊。預設情況下 kubeconfig 檔案就是位於$HOME/.kube
目錄下的config
檔案。
由於我們在上一章已經使用 kind 建立叢集,kind 會自動建立 kubeconig 並添加必要的資訊。
cat ~/.kube/config
結果如下
apiVersion: v1
clusters:
- cluster:
certificate-authority-data: DATA+OMITTED
server: https://127.0.0.1:39777
name: kind-wslkind
contexts:
- context:
cluster: kind-wslkind
user: kind-wslkind
name: kind-wslkind
current-context: kind-wslkind
kind: Config
preferences: {}
users:
- name: kind-wslkind
user:
client-certificate-data: DATA+OMITTED
client-key-data: DATA+OMITTED
我們可以為 kubectl 設置別名和自動補全,簡化操作的複查度。
# 在 bash 中設定當前 shell 的自動補全,要先安裝 bash-completion 包
source <(kubectl completion bash)
# 在你的 bash shell 中永久地新增自動補全
echo "source <(kubectl completion bash)" >> ~/.bashrc
# 為 `kubectl` 命令設定別名
alias k=kubectl
# 將 `kubectl` 命令的自動補全功能應用到 `k` 命令上
complete -o default -F __start_kubectl k
完成上面的設置後,我們就可以達成以下的操作:
k
來取代 kubectl
k cluster-info
# 等價於
kubectl cluster-info
kubectl clus
# -> 按下 tab 鍵
kubectl cluster-info
接下來,我們將列舉一些常用的 kubectl
指令及標記(flags)清單。無需完全記住這些用法,只需大致瀏覽一遍,對其有個基本的印象即可。當你在後續的實作中遇到困難時,可以隨時回到這一章節進行查詢。
--all-namespaces
參數,你應該要知道它的簡寫:kubectl -A
pods
也可以寫作 pod
、po
。想要查看資源的短別名,可以使用指令 kubectl api-resources
找到資源對應的 SHORTNAMES
欄位設定 kubectl
與哪個 Kubernetes 叢集進行通訊和修改組態資訊
kubectl config view # 顯示合併的 kubeconfig 組態
# 同時使用多個 kubeconfig 檔案並查看合併的組態
KUBECONFIG=~/.kube/config:~/.kube/kubconfig2
kubectl config view
# 顯示合併的 kubeconfig 組態和原始證書資料以及公開的 Secret
kubectl config view --raw
# 獲取 e2e 使用者的密碼
kubectl config view -o jsonpath='{.users[?(@.name == "e2e")].user.password}'
# 獲取 e2e 使用者的證書
kubectl config view --raw -o jsonpath='{.users[?(.name == "e2e")].user.client-certificate-data}' | base64 -d
kubectl config view -o jsonpath='{.users[].name}' # 顯示第一個使用者
kubectl config view -o jsonpath='{.users[*].name}' # 獲取使用者列表
kubectl config get-contexts # 顯示上下文列表
kubectl config get-contexts -o name # 獲取所有上下文的名稱
kubectl config current-context # 展示當前所處的上下文
kubectl config use-context my-cluster-name # 設定默認的上下文為 my-cluster-name
kubectl config set-cluster my-cluster-name # 在 kubeconfig 中設定叢集條目
# 在 kubeconfig 中組態代理伺服器的 URL,以用於該客戶端的請求
kubectl config set-cluster my-cluster-name --proxy-url=my-proxy-url
# 新增新的使用者組態到 kubeconf 中,使用 basic auth 進行身份認證
kubectl config set-credentials kubeuser/foo.kubernetes.com --username=kubeuser --password=kubepassword
# 在指定上下文中持久性地保存名字空間,供所有後續 kubectl 命令使用
kubectl config set-context --current --namespace=ggckad-s2
# 使用特定的使用者名稱和名字空間設定上下文
kubectl config set-context gce --user=cluster-admin --namespace=foo \
&& kubectl config use-context gce
kubectl config unset users.foo # 刪除使用者 foo
# 設定或顯示 context / namespace 的短別名
# (僅適用於 bash 和 bash 相容的 shell,在使用 kn 設定命名空間之前要先設定 current-context)
alias kx='f() { [ "$1" ] && kubectl config use-context $1 || kubectl config current-context ; } ; f'
alias kn='f() { [ "$1" ] && kubectl config set-context --current --namespace $1 || kubectl config view --minify | grep namespace | cut -d" " -f6 ; } ; f'
通過執行 kubectl apply
可以在 Kubernetes 集群中創建和更新資源。這是管理生產環境中 Kubernetes 應用的推薦方法。
kubectl apply -f ./my-manifest.yaml # 建立資源
kubectl apply -f ./my1.yaml -f ./my2.yaml # 使用多個檔案建立
kubectl apply -f ./dir # 基於目錄下的所有清單檔案建立資源
kubectl apply -f https://example.com/manifest.yaml # 從 URL 中建立資源(注意:這是一個示例域名,不包含有效的清單)
kubectl create deployment nginx --image=nginx # 啟動單實例 nginx
# 建立一個列印 “Hello World” 的 Job
kubectl create job hello --image=busybox:1.28 -- echo "Hello World"
# 建立一個列印 “Hello World” 間隔 1 分鐘的 CronJob
kubectl create cronjob hello --image=busybox:1.28 --schedule="*/1 * * * *" -- echo "Hello World"
kubectl explain pods # 獲取 Pod 清單的文件說明
# 從標準輸入建立多個 YAML 對象
kubectl apply -f - <<EOF
apiVersion: v1
kind: Pod
metadata:
name: busybox-sleep
spec:
containers:
- name: busybox
image: busybox:1.28
args:
- sleep
- "1000000"
---
apiVersion: v1
kind: Pod
metadata:
name: busybox-sleep-less
spec:
containers:
- name: busybox
image: busybox:1.28
args:
- sleep
- "1000"
EOF
# 建立有多個 key 的 Secret
kubectl apply -f - <<EOF
apiVersion: v1
kind: Secret
metadata:
name: mysecret
type: Opaque
data:
password: $(echo -n "s33msi4" | base64 -w0)
username: $(echo -n "jane" | base64 -w0)
EOF
什麼是組態檔案
Kubernetes 組態檔案(清單檔案) 用來描述叢集中的資源配置,通常使用 YAML 或 JSON 格式編寫。這些檔案是管理和部署 Kubernetes 資源的核心工具。
kubectl apply
指令可將組態檔案應用到 Kubernetes 叢集中,負責建立或更新資源。相比之下,雖然 kubectl create
也能用來建立資源,但它的靈活性較低,無法處理複雜的配置。
建立資源時,可以在指令後面加上 --dry-run -o yaml
參數,這會輸出資源的組態檔案格式,而不會執行創建操作。
kubectl run pod my-pod --image=nginx --dry-run=client -o yaml
# 將組態檔案格式保存到文件
kubectl run pod my-pod --image=nginx --dry-run=client -o yaml > my-pod.yaml
查看資源時,可以在指令中加上 -o yaml
,來輸出該資源的組態檔案。
kubectl get pod my-pod -o yaml
# get 命令的基本輸出
kubectl get services # 列出當前命名空間下的所有 Service
kubectl get pods --all-namespaces # 列出所有命名空間下的全部的 Pod
kubectl get pods -o wide # 列出當前命名空間下的全部 Pod 並顯示更詳細的資訊
kubectl get deployment my-dep # 列出某個特定的 Deployment
kubectl get pods # 列出當前命名空間下的全部 Pod
kubectl get pod my-pod -o yaml # 獲取一個 Pod 的 YAML
# describe 命令的詳細輸出
kubectl describe nodes my-node
kubectl describe pods my-pod
# 列出當前名字空間下所有 Service,按名稱排序
kubectl get services --sort-by=.metadata.name
# 列出 Pod,按重啟次數排序
kubectl get pods --sort-by='.status.containerStatuses[0].restartCount'
# 列舉所有 PV 持久卷,按容量排序
kubectl get pv --sort-by=.spec.capacity.storage
# 獲取包含 app=cassandra 標籤的所有 Pod 的 version 標籤
kubectl get pods --selector=app=cassandra -o \
jsonpath='{.items[*].metadata.labels.version}'
# 檢索帶有 “.” 鍵值,例如 'ca.crt'
kubectl get configmap myconfig \
-o jsonpath='{.data.ca\.crt}'
# 檢索一個 base64 編碼的值,其中的鍵名應該包含減號而不是下劃線
kubectl get secret my-secret --template='{{index .data "key-name-with-dashes"}}'
# 獲取所有工作節點(使用選擇算符以排除標籤名稱為 'node-role.kubernetes.io/control-plane' 的結果)
kubectl get node --selector='!node-role.kubernetes.io/control-plane'
# 獲取當前命名空間中正在運行的 Pod
kubectl get pods --field-selector=status.phase=Running
# 獲取全部節點的 ExternalIP 地址
kubectl get nodes -o jsonpath='{.items[*].status.addresses[?(@.type=="ExternalIP")].address}'
# 列出屬於某個特定 RC 的 Pod 的名稱
# 在轉換對於 jsonpath 過於複雜的場合,"jq" 命令很有用;可以在 https://jqlang.github.io/jq/ 找到它
sel=${$(kubectl get rc my-rc --output=json | jq -j '.spec.selector | to_entries | .[] | "\(.key)=\(.value),"')%?}
echo $(kubectl get pods --selector=$sel --output=jsonpath={.items..metadata.name})
# 顯示所有 Pod 的標籤(或任何其他支援標籤的 Kubernetes 對象)
kubectl get pods --show-labels
# 檢查哪些節點處於就緒狀態
JSONPATH='{range .items[*]}{@.metadata.name}:{range @.status.conditions[*]}{@.type}={@.status};{end}{end}' \
&& kubectl get nodes -o jsonpath="$JSONPATH" | grep "Ready=True"
# 使用自訂列檢查哪些節點處於就緒狀態
kubectl get node -o custom-columns='NODE_NAME:.metadata.name,STATUS:.status.conditions[?(@.type=="Ready")].status'
# 不使用外部工具來輸出解碼後的 Secret
kubectl get secret my-secret -o go-template='{{range $k,$v := .data}}{{"### "}}{{$k}}{{"\n"}}{{$v|base64decode}}{{"\n\n"}}{{end}}'
# 列出被一個 Pod 使用的全部 Secret
kubectl get pods -o json | jq '.items[].spec.containers[].env[]?.valueFrom.secretKeyRef.name' | grep -v null | sort | uniq
# 列舉所有 Pod 中初始化容器的容器 ID(containerID)
# 可用於在清理已停止的容器時避免刪除初始化容器
kubectl get pods --all-namespaces -o jsonpath='{range .items[*].status.initContainerStatuses[*]}{.containerID}{"\n"}{end}' | cut -d/ -f3
# 列出事件(Event),按時間戳排序
kubectl get events --sort-by=.metadata.creationTimestamp
# 列出所有警告事件
kubectl events --types=Warning
# 比較當前的叢集狀態和假定某清單被應用之後的叢集狀態
kubectl diff -f ./my-manifest.yaml
# 生成一個句點分隔的樹,其中包含為節點返回的所有鍵
# 在複雜的巢狀JSON結構中定位鍵時非常有用
kubectl get nodes -o json | jq -c 'paths|join(".")'
# 生成一個句點分隔的樹,其中包含為 Pod 等返回的所有鍵
kubectl get pods -o json | jq -c 'paths|join(".")'
# 假設你的 Pod 有默認的容器和默認的名字空間,並且支援 'env' 命令,可以使用以下指令碼為所有 Pod 生成 ENV 變數。
# 該指令碼也可用於在所有的 Pod 裡運行任何受支援的命令,而不僅僅是 'env'。
for pod in $(kubectl get po --output=jsonpath={.items..metadata.name}); do echo $pod && kubectl exec -it $pod -- env; done
# 獲取一個 Deployment 的 status 子資源
kubectl get deployment nginx-deployment --subresource=status
kubectl set image deployment/frontend www=image:v2 # 滾動更新 "frontend" Deployment 的 "www" 容器鏡像
kubectl rollout history deployment/frontend # 檢查 Deployment 的歷史記錄,包括版本
kubectl rollout undo deployment/frontend # 回滾到上次部署版本
kubectl rollout undo deployment/frontend --to-revision=2 # 回滾到特定部署版本
kubectl rollout status -w deployment/frontend # 監視 "frontend" Deployment 的滾動升級狀態直到完成
kubectl rollout restart deployment/frontend # 輪替重啟 "frontend" Deployment
cat pod.json | kubectl replace -f - # 通過傳入到標準輸入的 JSON 來替換 Pod
# 強制替換,刪除後重建資源。會導致服務不可用。
kubectl replace --force -f ./pod.json
# 為多副本的 nginx 建立服務,使用 80 連接埠提供服務,連接到容器的 8000 連接埠
kubectl expose rc nginx --port=80 --target-port=8000
# 將某單容器 Pod 的鏡像版本(標籤)更新到 v4
kubectl get pod mypod -o yaml | sed 's/\(image: myimage\):.*$/\1:v4/' | kubectl replace -f -
kubectl label pods my-pod new-label=awesome # 新增標籤
kubectl label pods my-pod new-label- # 移除標籤
kubectl label pods my-pod new-label=new-value --overwrite # 覆蓋現有的值
kubectl annotate pods my-pod icon-url=http://goo.gl/XXBTWq # 新增註解
kubectl annotate pods my-pod icon-url- # 移除註解
kubectl autoscale deployment foo --min=2 --max=10 # 對 "foo" Deployment 自動擴縮容
# 部分更新某節點
kubectl patch node k8s-node-1 -p '{"spec":{"unschedulable":true}}'
# 更新容器的鏡像;spec.containers[*].name 是必需的。因為它是一個合併性質的主鍵。
kubectl patch pod valid-pod -p '{"spec":{"containers":[{"name":"kubernetes-serve-hostname","image":"new image"}]}}'
# 使用帶位置陣列的 JSON patch 更新容器的鏡像
kubectl patch pod valid-pod --type='json' -p='[{"op": "replace", "path": "/spec/containers/0/image", "value":"new image"}]'
# 使用帶位置陣列的 JSON patch 停用某 Deployment 的 livenessProbe
kubectl patch deployment valid-deployment --type json -p='[{"op": "remove", "path": "/spec/template/spec/containers/0/livenessProbe"}]'
# 在帶位置陣列中新增元素
kubectl patch sa default --type='json' -p='[{"op": "add", "path": "/secrets/1", "value": {"name": "whatever" } }]'
# 通過修正 scale 子資源來更新 Deployment 的副本數
kubectl patch deployment nginx-deployment --subresource='scale' --type='merge' -p '{"spec":{"replicas":2}}'
kubectl edit svc/docker-registry # 編輯名為 docker-registry 的服務
KUBE_EDITOR="nano" kubectl edit svc/docker-registry # 使用其他編輯器 (預設使用 vi)
kubectl scale --replicas=3 rs/foo # 將名為 'foo' 的副本集擴縮到 3 副本
kubectl scale --replicas=3 -f foo.yaml # 將在 "foo.yaml" 中的特定資源擴縮到 3 個副本
kubectl scale --current-replicas=2 --replicas=3 deployment/mysql # 如果名為 mysql 的 Deployment 的副本當前是 2,那麼將它擴縮到 3
kubectl scale --replicas=5 rc/foo rc/bar rc/baz # 擴縮多個副本控製器
kubectl delete -f ./pod.json # 刪除在 pod.json 中指定的類型和名稱的 Pod
kubectl delete pod unwanted --now # 刪除 Pod 且無寬限期限(無優雅時段)
kubectl delete pod,service baz foo # 刪除名稱為 "baz" 和 "foo" 的 Pod 和服務
kubectl delete pods,services -l name=myLabel # 刪除包含 name=myLabel 標籤的 Pod 和服務
kubectl -n my-ns delete pod,svc --all # 刪除在 my-ns 名字空間中全部的 Pod 和服務
# 刪除所有與 pattern1 或 pattern2 awk 模式匹配的 Pod
kubectl get pods -n mynamespace --no-headers=true | awk '/pattern1|pattern2/{print $1}' | xargs kubectl delete -n mynamespace pod
# 立刻強制刪除 Pod
kubectl delete pod my-pod --grace-period=0 --force
kubectl logs my-pod # 獲取 Pod 日誌(標準輸出)
kubectl logs -l name=myLabel # 獲取含 name=myLabel 標籤的 Pod 的日誌(標準輸出)
kubectl logs my-pod --previous # 獲取上個容器實例的 Pod 日誌(標準輸出)
kubectl logs my-pod -c my-container # 獲取 Pod 容器的日誌(標準輸出, 多容器場景)
kubectl logs -l name=myLabel -c my-container # 獲取含 name=myLabel 標籤的 Pod 容器日誌(標準輸出, 多容器場景)
kubectl logs my-pod -c my-container --previous # 獲取 Pod 中某容器的上個實例的日誌(標準輸出, 多容器場景)
kubectl logs -f my-pod # 流式輸出 Pod 的日誌(標準輸出)
kubectl logs -f my-pod -c my-container # 流式輸出 Pod 容器的日誌(標準輸出, 多容器場景)
kubectl logs -f -l name=myLabel --all-containers # 流式輸出含 name=myLabel 標籤的 Pod 的所有日誌(標準輸出)
kubectl run -i --tty busybox --image=busybox:1.28 -- sh # 以互動式 Shell 運行 Pod
kubectl run nginx --image=nginx -n mynamespace # 在 “mynamespace” 命名空間中運行單個 nginx Pod
kubectl run nginx --image=nginx --dry-run=client -o yaml > pod.yaml
# 為運行 nginx Pod 生成規約並將其寫入到名為 pod.yaml 的檔案
kubectl attach my-pod -i # 掛接到一個運行的容器中
kubectl port-forward my-pod 5000:6000 # 在本地電腦上偵聽連接埠 5000 並轉發到 my-pod 上的連接埠 6000
kubectl exec my-pod -- ls / # 在已有的 Pod 中運行命令(單容器場景)
kubectl exec --stdin --tty my-pod -- /bin/sh # 使用互動 shell 訪問正在運行的 Pod (一個容器場景)
kubectl exec my-pod -c my-container -- ls / # 在已有的 Pod 中運行命令(多容器場景)
kubectl debug my-pod -it --image=busybox:1.28 # 在現有 Pod 中建立互動式偵錯會話並立即附加到此 Pod 上
kubectl debug node/my-node -it --image=busybox:1.28 # 在節點上建立互動式偵錯會話並立即附加到此節點上
kubectl top pod # 顯示默認命名空間中所有 Pod 的度量值
kubectl top pod POD_NAME --containers # 顯示給定 Pod 和其中容器的度量值
kubectl top pod POD_NAME --sort-by=cpu # 顯示給定 Pod 的指標並且按照 'cpu' 或者 'memory' 排序
kubectl cp /tmp/foo_dir my-pod:/tmp/bar_dir # 將 /tmp/foo_dir 本地目錄複製到遠端當前命名空間中 Pod 中的 /tmp/bar_dir
kubectl cp /tmp/foo my-pod:/tmp/bar -c my-container # 將 /tmp/foo 本地檔案複製到遠端 Pod 中特定容器的 /tmp/bar 下
kubectl cp /tmp/foo my-namespace/my-pod:/tmp/bar # 將 /tmp/foo 本地檔案複製到遠端 “my-namespace” 命名空間內指定 Pod 中的 /tmp/bar
kubectl cp my-namespace/my-pod:/tmp/foo /tmp/bar # 將 /tmp/foo 從遠端 Pod 複製到本地 /tmp/bar
kubectl cp
要求容器鏡像中存在 “tar” 二進制檔案。如果 “tar” 不存在,kubectl cp
將失敗。 對於進階用例,例如符號連結、萬用字元擴展或保留檔案權限,請考慮使用 kubectl exec
。
tar cf - /tmp/foo | kubectl exec -i -n my-namespace my-pod -- tar xf - -C /tmp/bar # 將 /tmp/foo 本地檔案複製到遠端 “my-namespace” 命名空間中 Pod 中的 /tmp/bar
kubectl exec -n my-namespace my-pod -- tar cf - /tmp/foo | tar xf - -C /tmp/bar # 將 /tmp/foo 從遠端 Pod 複製到本地 /tmp/bar
kubectl logs deploy/my-deployment # 獲取一個 Deployment 的 Pod 的日誌(單容器例子)
kubectl logs deploy/my-deployment -c my-container # 獲取一個 Deployment 的 Pod 的日誌(多容器例子)
kubectl port-forward svc/my-service 5000 # 偵聽本機連接埠 5000 並轉發到 Service 後端連接埠 5000
kubectl port-forward svc/my-service 5000:my-service-port # 偵聽本機連接埠 5000 並轉發到名字為 <my-service-port> 的 Service 目標連接埠
kubectl port-forward deploy/my-deployment 5000:6000 # 偵聽本機連接埠 5000 並轉發到 <my-deployment> 建立的 Pod 裡的連接埠 6000
kubectl exec deploy/my-deployment -- ls # 在 Deployment 裡的第一個 Pod 的第一個容器裡運行命令(單容器和多容器例子)
kubectl cordon my-node # 標記 my-node 節點為不可調度
kubectl drain my-node # 對 my-node 節點進行清空操作,為節點維護做準備
kubectl uncordon my-node # 標記 my-node 節點為可以調度
kubectl top node # 顯示所有節點的度量值
kubectl top node my-node # 顯示給定節點的度量值
kubectl cluster-info # 顯示主控節點和服務的地址
kubectl cluster-info dump # 將當前叢集狀態轉儲到標準輸出
kubectl cluster-info dump --output-directory=/path/to/cluster-state # 將當前叢集狀態輸出到 /path/to/cluster-state
# 查看當前節點上存在的現有污點
kubectl get nodes -o='custom-columns=NodeName:.metadata.name,TaintKey:.spec.taints[*].key,TaintValue:.spec.taints[*].value,TaintEffect:.spec.taints[*].effect'
# 如果已存在具有指定鍵和效果的污點,則替換其值為指定值
kubectl taint nodes foo dedicated=special-user:NoSchedule
列出所支援的全部資源類型和它們的簡稱、 API 組、 是否是名字空間範疇和 Kind。
kubectl api-resources
用於探索 API 資源的其他操作:
kubectl api-resources --namespaced=true # 所有命名空間範疇的資源
kubectl api-resources --namespaced=false # 所有非命名空間範疇的資源
kubectl api-resources -o name # 用簡單格式列舉所有資源(僅顯示資源名稱)
kubectl api-resources -o wide # 用擴展格式列舉所有資源(又稱 "wide" 格式)
kubectl api-resources --verbs=list,get # 支援 "list" 和 "get" 請求動詞的所有資源
kubectl api-resources --api-group=extensions # "extensions" API 組中的所有資源
要以特定格式將詳細資訊輸出到終端窗口,將 -o
(或者 --output
)參數新增到支援的 kubectl
命令中。
輸出格式 | 描述 |
---|---|
-o=custom-columns=<spec> |
使用逗號分隔的自訂列來列印表格 |
-o=custom-columns-file=<filename> |
使用 <filename> 檔案中的自訂列範本列印表格 |
-o=go-template=<template> |
列印在 golang 範本中定義的欄位 |
-o=go-template-file=<filename> |
列印在 <filename> 檔案中由 golang 範本定義的欄位 |
-o=json |
輸出 JSON 格式的 API 對象 |
-o=jsonpath=<template> |
列印 jsonpath 表示式中定義的欄位 |
-o=jsonpath-file=<filename> |
列印在 <filename> 檔案中定義的 jsonpath 表示式所指定的欄位 |
-o=name |
僅列印資源名稱而不列印其他內容 |
-o=wide |
以純文字格式輸出額外資訊,對於 Pod 來說,輸出中包含了節點名稱 |
-o=yaml |
輸出 YAML 格式的 API 對象 |
使用 -o=custom-columns
的示例:
# 叢集中運行著的所有鏡像
kubectl get pods -A -o=custom-columns='DATA:spec.containers[*].image'
# 列舉 default 名字空間中運行的所有鏡像,按 Pod 分組
kubectl get pods --namespace default --output=custom-columns="NAME:.metadata.name,IMAGE:.spec.containers[*].image"
# 除 "registry.k8s.io/coredns:1.6.2" 之外的所有鏡像
kubectl get pods -A -o=custom-columns='DATA:spec.containers[?(@.image!="registry.k8s.io/coredns:1.6.2")].image'
# 輸出 metadata 下面的所有欄位,無論 Pod 名字為何
kubectl get pods -A -o=custom-columns='DATA:metadata.*'
kubectl
的指令數不勝數,無法把全部的用法都展示出來,若在使用上遇到困難,只需要在指令後面加上 -h
就可以取得說明和範例
kubectl get pods -h
結果如下
Display one or many resources.
Prints a table of the most important information about the specified resources. You can filter the
list using a label selector and the --selector flag. If the desired resource type is namespaced you
will only see results in your current namespace unless you pass --all-namespaces.
By specifying the output as 'template' and providing a Go template as the value of the --template
flag, you can filter the attributes of the fetched resources.
Use "kubectl api-resources" for a complete list of supported resources.
Examples:
# List all pods in ps output format
kubectl get pods
# List all pods in ps output format with more information (such as node name)
kubectl get pods -o wide
# List a single replication controller with specified NAME in ps output format
kubectl get replicationcontroller web
# List deployments in JSON output format, in the "v1" version of the "apps" API group
kubectl get deployments.v1.apps -o json
# List a single pod in JSON output format
kubectl get -o json pod web-pod-13je7
# List a pod identified by type and name specified in "pod.yaml" in JSON output format
kubectl get -f pod.yaml -o json
# List resources from a directory with kustomization.yaml - e.g. dir/kustomization.yaml
kubectl get -k dir/
# Return only the phase value of the specified pod
kubectl get -o template pod/web-pod-13je7 --template={{.status.phase}}
# List resource information in custom columns
kubectl get pod test-pod -o
custom-columns=CONTAINER:.spec.containers[0].name,IMAGE:.spec.containers[0].image
# List all replication controllers and services together in ps output format
kubectl get rc,services
# List one or more resources by their type and names
kubectl get rc/web service/frontend pods/web-pod-13je7
# List the 'status' subresource for a single pod
kubectl get pod web-pod-13je7 --subresource status
Options:
-A, --all-namespaces=false:
If present, list the requested object(s) across all namespaces. Namespace in current
context is ignored even if specified with --namespace.
--allow-missing-template-keys=true:
If true, ignore any errors in templates when a field or map key is missing in the
template. Only applies to golang and jsonpath output formats.
--chunk-size=500:
Return large lists in chunks rather than all at once. Pass 0 to disable. This flag is beta
and may change in the future.
--field-selector='':
Selector (field query) to filter on, supports '=', '==', and '!='.(e.g. --field-selector
key1=value1,key2=value2). The server only supports a limited number of field queries per
type.
-f, --filename=[]:
Filename, directory, or URL to files identifying the resource to get from a server.
--ignore-not-found=false:
If the requested object does not exist the command will return exit code 0.
-k, --kustomize='':
Process the kustomization directory. This flag can't be used together with -f or -R.
-L, --label-columns=[]:
Accepts a comma separated list of labels that are going to be presented as columns. Names
are case-sensitive. You can also use multiple flag options like -L label1 -L label2...
--no-headers=false:
When using the default or custom-column output format, don't print headers (default print
headers).
-o, --output='':
Output format. One of: (json, yaml, name, go-template, go-template-file, template,
templatefile, jsonpath, jsonpath-as-json, jsonpath-file, custom-columns,
custom-columns-file, wide). See custom columns
[https://kubernetes.io/docs/reference/kubectl/#custom-columns], golang template
[http://golang.org/pkg/text/template/#pkg-overview] and jsonpath template
[https://kubernetes.io/docs/reference/kubectl/jsonpath/].
--output-watch-events=false:
Output watch event objects when --watch or --watch-only is used. Existing objects are
output as initial ADDED events.
--raw='':
Raw URI to request from the server. Uses the transport specified by the kubeconfig file.
-R, --recursive=false:
Process the directory used in -f, --filename recursively. Useful when you want to manage
related manifests organized within the same directory.
-l, --selector='':
Selector (label query) to filter on, supports '=', '==', and '!='.(e.g. -l
key1=value1,key2=value2). Matching objects must satisfy all of the specified label
constraints.
--server-print=true:
If true, have the server return the appropriate table output. Supports extension APIs and
CRDs.
--show-kind=false:
If present, list the resource type for the requested object(s).
--show-labels=false:
When printing, show all labels as the last column (default hide labels column)
--show-managed-fields=false:
If true, keep the managedFields when printing objects in JSON or YAML format.
--sort-by='':
If non-empty, sort list types using this field specification. The field specification is
expressed as a JSONPath expression (e.g. '{.metadata.name}'). The field in the API
resource specified by this JSONPath expression must be an integer or a string.
--subresource='':
If specified, gets the subresource of the requested object. Must be one of [status scale].
This flag is beta and may change in the future.
--template='':
Template string or path to template file to use when -o=go-template, -o=go-template-file.
The template format is golang templates
[http://golang.org/pkg/text/template/#pkg-overview].
-w, --watch=false:
After listing/getting the requested object, watch for changes.
--watch-only=false:
Watch for changes to the requested object(s), without listing/getting first.
Usage:
kubectl get
[(-o|--output=)json|yaml|name|go-template|go-template-file|template|templatefile|jsonpath|jsonpath-as-json|jsonpath-file|custom-columns|custom-columns-file|wide]
(TYPE[.VERSION][.GROUP] [NAME | -l label] | TYPE[.VERSION][.GROUP]/NAME ...) [flags] [options]
Use "kubectl options" for a list of global command-line options (applies to all commands).
在掌握了如何使用 kubectl
之後,我們就擁有了與 Kubernetes 叢集溝通的手段。現在,我們終於可以正式進入 K8s 的世界了。